/// <summary>/// 用于在多线程访问sqlite时防止同步写导致锁文件////// 使用方法:/// using (SQLiteWriteLock sqliteLock = new SQLiteWriteLock(SQLite链接字符串))/// {/// //sqlite 写操作代码/// }////// 可以通过在配置文件appSettings节中添加设置 SQLiteWriteLockTimeout 的value值控制锁等待的超时时间,该值必须为正整数数字,单位为毫秒,/// 默认的超时时间是1000ms/// </summary>public sealed class SQLiteWriteLock : IDisposable{#region 静态字段和属性const short WAIT_TIME = 5;static readonly object locker = new object();static Dictionary<string, int> _dbThreadIdDict = new Dictionary<string, int>();/// <summary>/// 获得写操作的超时时间,单位为毫秒,可以通过配置文件appSettings节中添加设置 SQLiteWriteLockTimeout 的value值控制锁等待的超时时间,该值必须为正整数数字,单位为毫秒/// 默认的超时时间是1000ms/// </summary>public static int SQLiteWriteLockTimeout {get {string configValule = ConfigurationManager.AppSettings["SQLiteWriteLockTimeout"];if (!string.IsNullOrEmpty(configValule)) {return int.Parse(configValule); }return 1000; } }#endregionprivate readonly string _connString;//隐藏无参构造函数private SQLiteWriteLock() { }public SQLiteWriteLock(string connString) { _connString = connString; AcquireWriteLock(); }#region 私有方法private void AcquireWriteLock() {int threadId = Thread.CurrentThread.ManagedThreadId;int waitTimes = 0;while (_dbThreadIdDict.ContainsKey(_connString) && _dbThreadIdDict[_connString] != threadId) { Thread.Sleep(WAIT_TIME); waitTimes = WAIT_TIME;#if DEBUG Console.WriteLine(_connString " wait for " waitTimes " ms");#endifif (waitTimes > SQLiteWriteLockTimeout) {throw new TimeoutException("SQLite等待写操作超时"); } }lock (locker) {if (!_dbThreadIdDict.ContainsKey(_connString)) _dbThreadIdDict.Add(_connString, threadId); } }private void ReleaseWriteLock() {lock (locker) {if (_dbThreadIdDict.ContainsKey(_connString)) { _dbThreadIdDict.Remove(_connString); } } }#endregion#region IDisposable 成员public void Dispose() { ReleaseWriteLock(); }#endregion}
下载SQLite多线程写入 出现锁文件的解决方案用户还喜欢
- 18480 文章数
- 500万+ 热度
作者专栏
编辑推荐
- 淡抹u2引擎,修复内容较多,物有所值
- 界域传说·经典巨作=传世单机(一键安装)
- 丸子版本(175个传世版本大集合)
- GS版本:神话公益服务端+客户端
- 图片放大工具(放大图片不模糊)
- 剪映无限制VIP版
- 传奇世界客户端下载器,史上最全传世客户端
- 传世GS20220920商业引擎注册+登录配置器 解压密码是1
- U2官方排行榜游戏网关 支持元神,支持传家宝
- GS开战传世客户端+服务端
- (淡漠夕阳)u2引擎合区工具
- 传世GS引擎消除“你的游戏客户端版本号过旧,请及时更新”提示
- 传世一机多区双线路配置器--免密码版本
- 传世凤凰登陆器劫持修复软件
- SQLite3 for Navicat
- 传奇世界npc对话框编辑工具
- 传世GS落霞铭文服务器端
- gs_20210409引擎包+注册机(无限制)
- 传奇世界NPC对话封包查看器[支持时长版和极速版]
- 彩虹引擎传世脚本编辑工具1.7版来了,支持函数脚本翻译
评论